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In the Claims: 

1 . (Original) A method for multicasting data comprising: 

adding the data to a queue; 

placing a reference to the data and to a multicast tree into a to-do list; 

for each of the leaves of the multicast tree, obtaining a data element pointer and a leaf to be 

processed pointer from the to-do list; and 
scheduling the data to be output to each of the leaves of the multicast tree based on the data 

element pointer and the leaf to be processed pointer. 

2. (Original) The method of claim 1 further comprising: 

updating the leaf to be processed pointer in the to-do list for each instance of scheduling the 
data to be output to each of the leaves. 

3. (Original) The method of claim 2 further comprising: 

setting a copy count to an initial value; 

adjusting the copy count based on a number of actual copies made. 

4. (Original) The method of claim 3 wherein the step of setting the copy count to the initial value 

further comprises: 

setting the copy count to a maximum value initially, and 
wherein the step of adjusting the copy count further comprises: 

decrementing the copy count for each of the actual copies made. 

5. (Original) The method of claim 3 wherein the step of adjusting the copy count is performed in 

response to the step of scheduling the data to be output to each of the leaves of the multicast 
tree. 

6. (Original) The method of claim 4 wherein the step of scheduling the data to be output to each of 

the leaves of the multicast tree further comprises: 
counting every one of the leaves of the multicast tree. 
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7. (Original) The method of claim 4 wherein the step of adjusting the copy count is performed based 
on reaching a leaf to be processed pointer that points to itself. 
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8. (Canceled) 
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9. (Original) A method for multicasting data comprising: 

storing queue context information and data context information pertaining to the data; 
determining which of the data to transmit as output data and a destination to which it shall be 
transmitted based on the queue context information and the data context information; 
transmitting the output data to the destination; 

determining a number of destinations to which the output data has been transmitted; and 
determining a number of destinations intended to receive the output data. 

10. (Original) The method of claim 9 further comprising: 

when the number of destinations to which the output data has been transmitted indicates that 
the output data has been transmitted to the number of destinations intended to receive 
the output data, concluding the queuing of the output data. 

11. (Original) The method of claim 10 further comprising: 

updating the queue context information for a root connection. 

12. (Original) The method of claims 1 1 further comprising: 

obtaining a data element pointer and a leaf to be processed pointer from a to-do list, wherein 
the step of determining which of the data to transmit as the output data is based on the 
data element pointer and the leaf to be processed pointer. 

13. (Original) The method of claim 12 further comprising: 

updating a number of leaves counter. 

14. (Original) The method of claim 12 further comprising: 

adjusting a copy count, wherein the copy count is used to determine the number of destinations 
to which the output data has been transmitted. 

1 5. (Original) The method of claim 14 wherein the step of adjusting the copy count further comprises: 

decrementing the copy count for each of the number of destinations to which the output data 
has been transmitted, wherein the copy count had been initialized to a maximum value. 
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16. (Canceled) 

17. (Canceled) 

18. (Canceled) 

19. (Canceled) 

20. (Canceled) 
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